--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
@@ -210,6 +210,45 @@ static struct board_info __initdata boar
 		.num_board_fixups		= ARRAY_SIZE(dsl2751b_e1_fixups),
 	},
 };
+
+static struct board_info __initdata board_FAST2704N = {
+	.name				= "F@ST2704N",
+	.expected_cpu_id		= 0x6318,
+
+	.has_pci			= 1,
+	.use_fallback_sprom		= 1,
+
+	.has_enetsw			= 1,
+
+	.has_ohci0			= 1,
+	.has_ehci0			= 1,
+	.num_usbh_ports			= 1,
+
+	.enetsw = {
+		.used_ports = {
+			[0] = {
+				.used	= 1,
+				.phy_id = 1,
+				.name	= "Port 1",
+			},
+			[1] = {
+				.used	= 1,
+				.phy_id	= 2,
+				.name	= "Port 2",
+			},
+			[2] = {
+				.used	= 1,
+				.phy_id	= 3,
+				.name	= "Port 3",
+			},
+			[3] = {
+				.used	= 1,
+				.phy_id	= 4,
+				.name	= "Port 4",
+			},
+		},
+	},
+};
 #endif /* CONFIG_BCM63XX_CPU_6318 */
 
 /*
@@ -2203,6 +2242,7 @@ static const struct board_info __initcon
 	&board_96318ref,
 	&board_96318ref_p300,
 	&board_dsl_2751b_d1,
+	&board_FAST2704N,
 #endif
 #ifdef CONFIG_BCM63XX_CPU_6328
 	&board_96328avng,
@@ -2300,6 +2340,7 @@ static struct of_device_id const bcm963x
 	{ .compatible = "brcm,bcm96318ref", .data = &board_96318ref, },
 	{ .compatible = "brcm,bcm96318ref_p300", .data = &board_96318ref_p300, },
 	{ .compatible = "d-link,dsl-275xb-d", .data = &board_dsl_2751b_d1, },
+	{ .compatible = "sagem,f@st2704n", .data = &board_FAST2704N, },
 #endif
 #ifdef CONFIG_BCM63XX_CPU_6328
 	{ .compatible = "adb,a4001n", .data = &board_A4001N, },
